package cn.wenhaha.app.config;

import cn.dev33.satoken.session.SaSession;
import cn.dev33.satoken.stp.StpInterface;
import cn.dev33.satoken.stp.StpUtil;
import cn.hutool.core.util.StrUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import java.util.List;

@Component
@Slf4j
public class AuthorInterfaceImpl implements StpInterface {

    /**
     * 返回一个账号所拥有的权限码集合
     */
    @Override
    public List<String> getPermissionList(Object loginId, String s) {
        SaSession sessionByLoginId = StpUtil.getSessionByLoginId(loginId);
        String role = sessionByLoginId.get("role", "");
        return StrUtil.split(role,';');
    }

    /**
     * 返回一个账号所拥有的角色标识集合 (权限与角色可分开校验)
     */
    @Override
    public List<String> getRoleList(Object loginId, String s) {
        SaSession sessionByLoginId = StpUtil.getSessionByLoginId(loginId);
        String role = sessionByLoginId.get("role", "");
        log.info("当前登录角色为： {}",role);
        return StrUtil.split(role,';');
    }
}
